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(54) Method and apparatus for providing electronic mail services during network unavailability 



(57) The present invention relates to a mobile de- 
vice (200) for use with a wireless data communication 
providing electronic mail services centrally managed by 
a mail server. The mobile device stores electronic mail 
resources in a memory storage device that is persistent 
and not subjected to cache removal processing. The 
mobile device also has a display device (228), which dis- 
plays at least a part of one or more of the electronic mail 



resources, and an electronic mail processor (226) which 
can perform an electronic mail operation with respect to 
the electronic mail resources stored in the memory stor- 
age device even when the wireless data communication 
network is not available to the mobile device. Accord- 
ingly, the mobile device can locally perform locally elec- 
tronic mail services thereby avoiding significant delays 
when the network is unavailable. 
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Description 

BACKGROUND OF THE INVENTION 

1 . Field of the Invention 

[0001] The present invention relates to providing elec- 
tronic mail services, and more particularly, to providing 
electronic mail services during network unavailability. 

2. Description of the Related Art 

[0002] Electronic mail (email) is a popular way to com- 
municate with others. Electronic mail systems operate 
to send messages over a network. The network can in- 
clude internal networks and external (e.g., public) net- 
works. An example of an internal network is a corporate 
network, and an example of an external network is the 
Internet. Typically, the electronic mail systems are cor- 
porate wide systems that reside on an internal network 
but also permit coupling to an external network so that 
messages can be exchanged with other electronic mail 
systems. 

[0003] Recently, Internet-based electronic mail sys- 
tems have been developed and implemented to provide 
electronic mail sen/ices over the Internet. In such sys- 
tems, there is no internal network because the electronic 
mail system resides on the Internet. The electronic mail 
system has a mail server that interacts with users' net- 
work browsers so that users are able to request elec- 
tronic mail sen/ices which are perlormed by the mail 
server. Typically, the mail server is a Hyper Text Transfer 
Protocol (HTTP) server. 

[0004] These Internet-based electronic mail systems 
have been implemented over wired networks as well as 
wireless networks. The availability of the network deter- 
mines whether a client application (e.g., network brows- 
er) is in communication with the mail server. The client 
application operates on a local machine, whereas the 
mail server operates on a remote machine. In the case 
of wired networks, the local machine is, for example, a 
desktop computer. In the case of wireless networks, the 
local machine is a mobile device. For example, the mo- 
bile device can be a mobile telephone, a personal digital 
assistant (PDA) or a portable computerthat has wireless 
access to the mail server. 

[0005] One problem with the conventional electronic 
mail systems is that the operation of client applications 
are very much dependent on availability of their network. 
In other words, when the network is unavailable, the cli- 
ent applications can become "hung", namely stopping 
further processing until a response from a remote server 
via the network is received. The network can be a wired 
network or a wireless network. Unavailability of a wired 
network can be due to high congestion or server failure. 
Unavailability of a wireless network can result from a us- 
er of a mobile device (supporting the client application) 
exceeding the geographic range of coverage. Unavail- 



ability also effectively results from a wireless network 
having high latencies, sporadic connectivity, high con- 
gestion or server failure. Because of the dependency of 
the operation of client applications on the availability of 
s networks, client applications often have to wait for re- 
sources from a mail server. These wait times are unac- 
ceptably long when the network is unavailable to the cli- 
ent applications. 

[0006] Computers or mobile devices are often provid- 

10 ed with cache memories that temporarily store previous- 
ly requested and obtained resources from remote serv- 
ers. A cache memory is helpful in reducing the depend- 
ency of the computers or mobile devices on network 
availability. However, the cache memory is only helpful 

'5 when the newly requested resource happens to reside 
in the cache memory. Hence : if the newly requested re- 
source was not previously requested, then the newly re- 
quested resource would not be stored in the cache 
memory. Also, even if the newly requested resource 

20 were at one point in time stored in the cache memory, a 
reclamation or clean-up algorithm could have removed 
it from the cache memory to provide space for newer 
requested resources. Still further, the cache memory 
has to be relatively large to store all the resources likely 

25 to be requested. However, mobile devices (particularly 
hand-held mobile devices) need to keep cache memo- 
ries relatively small due to power, cost and space limi- 
tations. 

[0007] In the case of Internet-based electronic mail 
30 systems, a network browser operates on the computer 
or mobile device to enable access and manipulation 
their electronic mail residing on a mail server over the 
Internet. Since the network browsers often request elec- 
tronic mail resources from remote mail servers over the 
35 network, the network browsers are particularly sensitive 
to network unavailability (e.g., due to out of coverage, 
high latencies, or sporadic connectivity). Consequently, 
even with a conventional cache memory, it is common 
for network unavailability to induce significant delays for 
40 the users of network browsers on computers or mobile 
devices. 

[0008] Thus, there is a need for techniques to reduce 
delays faced by users seeking to perform electronic mail 
services with a mail server across a network. 

45 

SUMMARY OF THE INVENTION 

[0009] Broadly speaking, the invention relates to im- 
proved techniques for providing electronic mail services 

50 across a network. A mail server and its clients commu- 
nicate through the network. Although the mail server 
centrally manages the electronic mail services : the cli- 
ents are able to themselves locally perform certain elec- 
tronic mail services when the network is unavailable. Ac- 

55 cordingly, clients seeking to perform electronic mail 
services no longer endure significant delays when the 
network is unavailable. The network can be at least tem- 
porarily unavailable for a variety of reasons, including: 
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congestion, out of range, network failure, etc. The net- 
work can be wired or wireless. The invention is particu- 
larly well suited for networks having sporadic connectiv- 
ity, high latencies or excessive traffic. 
[0010] The inventbn can be implemented in numer- 
ous ways, including as a method, a computer readable 
medium, an apparatus, and a system. Several embod- 
iments of the invention are discussed below. 
[001 1 ] As a mobile device for use with a wireless data 
communication network, an embodiment of the inven- 
tion includes: a memory storage device that stores elec- 
tronic mail resources; an electronic mail processor that 
performs an electronic mail operation with respect to the 
electronic mail resources stored in said memory storage 
device, and where the electronic mail operation can be 
carried out at said mobile device even when the wireless 
data communication network is not available to said mo- 
bile device: and a display device that displays at least a 
part of one or more of the electronic mail resources. 
[001 2] As a method for interacting with electronic mail 
messages on a mobile device, the mobile device being 
able to communicate with a mail server at least in part 
through a wireless data network, an embodiment of the 
invention includes the acts of: pre-loading electronic 
mail message resources into a storage device of the mo- 
bile device: receiving a request to view an electronic 
mail list; determining whether the electronic mail list is 
available from the storage device of the mobile device; 
receiving the electronic mail list from the storage device 
when the electronic mail list is determined to be availa- 
ble from the storage device of the mobile device; re- 
questing and subsequently receiving the electronic mail 
list from the mail server when the electronic mail list is 
determined not to be available from the storage device 
of the mobile device; and displaying the received elec- 
tronic mail list. 

[001 3] As a method for interacting with electronic mail 
messages on a mobile device, the mobile device being 
able to connect to a remote mail server through a wire- 
less data network, an embodiment of the invention in- 
cludes: displaying an electronic mail list on a display 
screen of the mobile device, the electronic mail list in- 
cluding one or more entries that identify particular elec- 
tronic mail messages: selecting one of the entries of the 
electronic mail list being displayed on the display screen 
of the mobile device; performing an operation on the 
electronic mail message associated with the selected 
entry without delay due to the unavailability of the wire- 
less data network to the mobile device; and asynchro- 
nously sending a notification to the remote mail server 
based on the operation performed on the electronic mail 
message associated with the selected entry when the 
wireless data network is available to the mobile device. 
[0014] As a computer readable medium including 
computer program code for interacting with electronic 
mail messages on a computing device, the computing 
device being able to communicate with a mail server at 
least in part through a data network, an embodiment of 
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the invention includes: computer program code config- 
ured to pre-load electronic mail message resources into 
a storage device of the computing device; computer pro- 
gram code configured to receive a request to view an 

5 electronic mail list; computer program code configured 
to determine whether the electronic mail list is available 
from the storage device of the computing device; com- 
puter program code configured to receive the electronic 
mail list from the storage device when the electronic mail 

10 list is determined to be available from the storage device 
of the computing device; computer program code con- 
figured to request and subsequently receive the elec- 
tronic mail list from the mail server when the electronic 
mail list is determined not to be available from the stor- 

is age device of the computing device; and computer pro- 
gram code configured to display the received electronic 
mail list. 

[001 5] As a computer readable medium for interacting 
with electronic mail messages on a computing device, 

20 the computing device being able to connect to a remote 
mail server through a data network, an embodiment of 
the invention includes: computer program code config- 
ured to display an electronic mail list on a display screen 
of the computing device, the electronic mail list including 

25 one or more entries that identify particular electronic 
mail messages: computer program code configured to 
select one of the entries of the electronic mail list being 
displayed on the display screen of the computing de- 
vice: computer program code configured to perform an 

30 operation on the electronic mail message associated 
with the selected entry without delay due to the unavail- 
ability of the wireless data network to the computing de- 
vice: and computer program code configured to asyn- 
chronously send a notification to the remote mail server 

35 based on the operation performed on the electronic mail 
message associated with the selected entry when the 
data network is available to the computing device. 
[0016] The advantages of the invention are numer- 
ous. Several advantages that embodiments of the in- 

40 vention may include are as lollows. One advantage of 
the invention is that electronic mail services can be per- 
formed on electronic mail messages even when the net- 
work is unavailable. Clients, e.g., mobile devices, are 
able to perform electronic mail services regardless of 

45 network availability. As a result, clients experience bet- 
ter responsiveness and less waiting. Another advantage 
of the invention is that a mail server located on the net- 
work is able to be kept current by use of asynchronous 
messaging. Still another advantage of the invention is 

so the intelligent management of the memory resources of 
the clients which are being consumed by the electronic 
mail services. 

[0017] Other aspects and advantages of the invention 
will become apparent from the following detailed de* 
55 scription, taken in conjunction with the accompanying 
drawings which illustrate, by way of example, the prin- 
ciples of the invention. 
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BRIEF DESCRIPTION OF THE DRAWINGS 

[0018] The present invention will be readily under- 
stood by the following detailed description in conjunction 
with the accompanying drawings, wherein like reference 
numerals designate like structural elements, and in 
which: 

FIG. 1 is a block diagram ot a wireless data com- 
munications system according to an embodiment of 
the invention; 

FIG. 2 is a blockdiagram of a mobile device accord- 
ing to an embodiment of the invention; 
FIG. 3 is a flow diagram of electronic mail channel 
processing; 

FIG. 4 is a flow diagram of electronic mail push 
processing according to an embodiment of the in- 
vention; 

FIG. 5 is a flow diagram of electronic mail list display 
processing according to an embodiment of the in- 
vention; 

FIG. 6 is a flow diagram of electronic mail opera- 
tions processing according to an embodiment of the 
invention; 

FIG. 7A is a flow diagram of view processing ac- 
cording to an embodiment of the invention; 
FIG. 7B is a flow diagram of an optional enhance- 
ment to the view processing 700 according to an 
embodiment of the invention; 
FIG. 8 is a flow diagram of delete processing ac- 
cording to an embodiment of the invention; 
FIG. 9 is a flow diagram of fax processing according 
to an embodiment of the invention; 
FIG. 10 is a flow diagram of reply processing ac- 
cording to an embodiment of the invention; 
FIG. 1 1 is a flow diagram of new message process- 
ing according to an embodiment of the invention; 
FIG. 12 is a flow diagram of asynchronous request 
send processing according to an embodiment of the 
invention: 

FIG. 1 3 is a flow diagram of server push processing 
according to an embodiment of the invention; and 
FIG. 14 is a block diagram of a mobile device ac- 
cording to another embodiment of the invention. 

DETAILED DESCRIPTION OF THE INVENTION 

[0019] The invention relates to improved techniques 
for providing electronic mail services across a network. 
A mail server and its clients communicate through the 
network. Although the mail server centrally manages the 
electronic mail services, clients are able to themselves 
locally perform certain electronic mail services when the 
network is unavailable. Accordingly, clients seeking to 
perform electronic mail services no longer endure sig- 
nificant delays when the network is unavailable. The 
network can be at least temporarily unavailable for a va- 
riety of reasons, including: congestion, out of range, net- 



work failure, etc. The network can be wired or wireless. 
The invention is particularly well suited for networks hav- 
ing sporadic connectivity, high latencies or excessive 
traffic. 

5 [0020] While the invention is useful for both wired and 
wireless networks, the invention is described below with 
reference to a wireless communication system since 
wireless networks more often suffer network unavaila- 
bility. In a wireless communication system, a wireless 

*0 network (wireless carrier network) generally supports 
connection of a plurality of mobile devices to a wired net- 
work. The mobile devices communicate with server ma- 
chines on the wired network to request and receive var- 
ious resources. The wired network can be of different 

is types. One type of wired network is the Internet. The 
invention pertains to the facilitating of operation of mo- 
bile devices when the wireless or wired network is una- 
vailable such that the mobile devices are unable to com- 
municate with the server machines, such as a mail serv- 

20 er. 

[0021] Embodiments of the invention are discussed 
below with reference to FIGs. 1-14. However, those 
skilled in the art will readily appreciate that the detailed 
description given herein with respect to these figures is 

25 for explanatory purposes as the invention extends be- 
yond these limited embodiments. 
[0022] FIG. 1 is a block diagram of a wireless data 
communications system 100 according to an embodi- 
ment of the invention. The wireless data communication 

30 system 100 includes mobile devices 102 and 104. Nor- 
mally, the wireless data communication system 100 
supports a large number of mobile devices, and thus the 
mobile devices 102 and 104 are representative of the 
mobile devices used. These mobile devices 102 and 

35 104 can couple to a network gateway 106 through a 
wireless network 108. The network gateway 106 can al- 
so be referred to as a proxy server or wireless data serv- 
er. The network gateway 106 is able to exchange infor- 
mation with a mail server 110. The network gateway 1 06 

40 and the mail server 1 10 are interconnected through a 
network 112. The mail server 1 10 manages the storage 
and delivery of electronic mail messages to the appro- 
priate location (e.g., the mobile devices 102 and 104). 
Typically, the network 112 is a wired network. As an ex- 

45 ample, the network 112 can be a local area network 
(LAN), a wired area network (WAN) : the Internet, or 
some combination thereof. In one embodiment, the net- 
work 112 is the Internet and the network gateway 106 
and the mail server 1 10 are HTTP servers. 

so [0023] Conventionally, all the resources associated 
with the electronic mail service were stored only on the 
mail server. Hence, the mobile devices had to be in net- 
work communication with the mail server in order to per- 
form electronic mail operations, such as viewing, delet- 

55 ing or creating electronic mail messages. This is also 
true for wired communication systems where local com- 
puters are required to be in network communication with 
a mail server in order to perform electronic mail opera- 
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tions. When in network communication, the mobile de- 
vices (or local computers) would request a list of elec- 
tronic mail from the mail server through the network. 
Once the request list of electronic mail is received, the 
list would be displayed to a user The user could then 
perform one of the electronic mail operations on one of 
the listed electronic mail messages. However, the elec- 
tronic mail operations were all performed by the mail 
server and thus network communication was required. 
For example, if a user requested to delete a certain mes- 
sage from the list of electronic mail, then the request 
would be sent to the mail server. If the network was un- 
available, the request would not be sent and thus the 
mobile device (or local computer) would wait for the net- 
work availability to return or eventually the mobiledevice 
(or local machine) would give up. Once received at the 
mail server, the mail server would process the delete 
request and then modify the list of electronic mail for the 
mobile device (or local machine). The modified list of 
electronic mail would then be sent to the mobile device 
(or local machine), again requiring network availability. 
[0024] Due to sporadic connectivity high latencies, 
congestion, range limitations, obstructions, network fail- 
ures, etc., networks are occasionally unavailability (at 
least temporarily) to mobile devices (or local machines). 
During such network unavailability, conventional elec- 
tronic mail systems do not allow the mobile machines 
(local machines) to complete electronic mail operations. 
Often, this causes the mobile device (or local machine) 
to incur delays which are unsatisfactory to the users of 
the mobile devices (or local machines). Thus, the con- 
ventional approaches to providing electronic mail to lo- 
cal devices are unsatisfactory. Namely, when the wire- 
less network is not available to the mobile devices, the 
mobile devices are not able to perform any electronic 
mail functions. 

[0025] According to the invention, the mobile devices 
102 and 104 are able to perform many electronic mail 
functions even though the network is unavailable to the 
mobile devices. The mobile devices 102 and 104 are no 
longer dependent on the availability of network connec- 
tivity to the mail server 1 1 0 in order to provide electronic 
mail functions on the mobile devices 102 and 104. 
[0026] The mobile devices can take a variety of forms. 
Examples of mobile devices include mobile computing 
devices, cellular or mobile phones, portable computer 
devices, personal digital assistant (PDA) devices. 
[0027] FIG. 2 is a block diagram of a mobile device 
200 according to an embodiment of the invention. The 
mobile device 200 is, for example, suitable for use as 
the mobile device 1 02 or the mobile device 1 04 illustrat- 
ed in FIG. 1 . The mobile device 200 is particularly suited 
for wireless communications through a wireless network 
where connectivity is sporadic or high-latency condi- 
tions are present. 

[0028] The mobile device 200 includes an application 
program that operates on the mobile device 200. In one 
embodiment, the application program 202 is a network 



browser. In one embodiment, the network browser is a 
micro-browser. A micro-browser is a network browser 
designed for a small screen interface such as with hand- 
held mobile devices. As an example, a micro-browser 

5 is produced by Unwired Planet, Inc. located at 800 
Chesapeake Drive, Redwood City, CA 94063. The ap- 
plication program 202 interacts with a memory 204 that 
stores data for use by the application program 202. The 
memory 204 includes a persistent storage 206 and a 

10 cache storage 208. The persistent storage 206 is an ar- 
ea of the memory 204 that is protected from cache re- 
placement or clean-up processing. The cache storage 
208, on the other hand, is subject to cache replacement 
and cache-cleanup processing as is normal with cache 

is type memory operations. A communication link 210 (or 
interface) connects with the memory 204 to the applica- 
tion program 202. The memory 204 is also often of a 
limited size due to limitations on size and power for mo- 
bile devices, particularly hand-held mobile devices. 

20 [0029] The mobile device 200 also includes a syn- 
chronous request manager 21 2 that couples to the com- 
munication link 210. The synchronous request manager 
212 manages synchronous requests for resources by 
the mobile device 200 to the mail server 110 (or other 

25 remote servers) via a communication link 214. In re- 
sponse to the synchronous requests, the synchronous 
request manager 212 also receives resources from the 
mail server 110 (or other remote servers) via the com- 
munication link 21 4. An asynchronous request manager 

30 216 is also coupled to the communication link 210. The 
asynchronous request manager 216 operates to man- 
age asynchronous requests for resources from the mo- 
bile device 200 to the mail server 110 (or other remote 
servers) via a communication link 218. The asynchro- 

35 nous request manager is connected to an asynchronous 
request queue 220 that is also connected to the com- 
munication link 210. The asynchronous request queue 
220 stores asynchronous requests that are to be trans- 
mitted by the asynchronous request manger 216 to the 

40 mail server 110 (or other remote servers) when the net- 
work is available to the mobile device 200. Also, when 
the network is available to the mobile device 200, a push 
manager 222 receives incoming resources over a com- 
munication link 224. The push manager 222 is coupled 

45 to the communication bus 210 and is thus able to store 
the incoming resources in the memory 204. 
[0030] The mobile device 200 also includes an elec- 
tronic mail client application 226. The electronic mail cli- 
ent application 226 is coupled with the application pro- 

50 gram 202 so that electronic mail functions (operations) 
can be performed on the mobile device 200. As is ex- 
plained in more detail below, the electronic mail client 
application 226 is able to operate properly even when 
the network is unavailable. The mobile device 200 also 

55 includes a display device (or screen) 228 that is coupled 
to the communication link 210. Among other things, the 
display device 228 operates to display electronic mail 
information for a user of the mobile device 200. 
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[0031] FIG. 3 is a flow diagram of electronic mail chan- 
nel processing 300. The electronic mail channel 
processing 300 is performed by a mobile device when 
operating to pre-load channel resources into a memory 
of the mobile device. As an example, the channel re- 
sources can be pre-loaded into the memory 204 (name- 
ly, the persistent storage 206) of the mobile device 200 
illustrated in FIG. 2. The advantage of the pre-loading 
is that the resources needed by the mobile device in in- 
teracting with the electronic mail are rapidly available 
regardless of network availability because the resourc- 
es are resident on the mobile device. 
[0032] The electronic mail channel processing 300 in- 
itially identifies 302 the resources of the electronic mail 
channel that is to be pre-loaded. Typically, various chan- 
nels are available to the mobile device. Hence, a user 
of the mobile device is able to select those channels they 
desire to have resident in the memory (namely, the per- 
sistent storage 206) of the mobile device 200. Here, it 
is assumed that the electronic mail channel is to be pre- 
loaded into the memory of the mobile device. The iden- 
tification of the resources of the electronic mail channel 
are those resources that would be needed by the mobile 
device when performing operations associated with the 
electronic mail on the mobile device. In one embodi- 
ment, the resources of the electronic mail channel in- 
clude: electronic mail message list; contents of the mes- 
sages; menu and data entry screens for electronic mail 
operations. 

[0033] Following block 302, a first resource of the 
electronic mail channel is selected 304. Then, a decision 
block 306 determines whether the selected resource is 
found within the memory. Here, the memory pertains to 
the memory 204 (namely, the persistent storage 206) 
illustrated in FIG. 2. When the decision block 306 deter- 
mines that the selected resource is not stored in the 
memory, then the resource is requested 308 from a re- 
mote server (e.g., the mail server 110) in an asynchro- 
nous manner. For example, with respect to FIG. 2, the 
resource being requested would be forwarded to the 
asynchronous request queue 220 and then eventually 
transmitted to the mail server 110 by the asynchronous 
request manager 21 6 when network availability permits. 
Because the request 308 for the resource is performed 
in an asynchronous manner, there is no need for the 
electronic mail channel processing 300 to await the ar- 
rival of the requested resource. Thus, the processing 
continues once the request for the resource is placed in 
the asynchronous request queue 220. The arrival of the 
previously requested resources are received in the 
background, for example, via the push manager 222. 
[0034] Following block 308, as well as following the 
decision block 306 when the selected resource is in the 
memory, a decision block 31 0 determines whether there 
are more resources of the electronic mail channel to be 
pre-loaded. When the decision block 310 determines 
that there are more resources to be processed, the elec- 
tronic mail channel processing 300 returns to repeat the 
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block 304 and subsequent blocks. When repeating the 
block 304, the next resource of the electronic mail chan- 
nel is selected. Alternatively, when the decision block 
310 determines that there are no more resources to be 
5 processed, the electronic mail channel processing 300 
is complete and ends. 

[0035] FIG. 4 is a flow diagram of electronic mail push 
processing 400 according to an embodiment of the in- 
vention. The electronic mail push processing 400 is per- 

10 formed on a mobile device. The electronic mail push 
processing 400 is the basic operation of the mobile de- 
vice when receiving an incoming resource from the mail 
server over a push channel and arriving at the push 
manager 222 of the mobile device 200. 

75 [0036] The electronic push processing 400 begins a 
decision block 402. The decision block 402 determines 
whether an electronic mail resource has been received. 
Typically, the mobile device can receive a variety of dif- 
ferent types of resources over the push channel. In the 

20 case of the mobile device 200, the incoming resources 
to the mobile device 200 would be received by the push 
manager 222 and stored in the memory 204. In any 
event, the decision block 402 operates to invoke the 
electronic mail push processing 400 when an electronic 

25 mail resource has been received at the mobile device. 
When it is determined that an electronic mail resource 
has been received, the received electronic mail re- 
source is stored 404 in persistent storage within the mo- 
bile device. For example, with respect to FIG. 2, the re- 

30 ceived electronic mail resource can be stored in the per- 
sistent storage 206 of the memory 204. 
[0037] Following block 404, the electronic mail push 
processing 400 returns to the beginning of the electronic 
mail push processing 400 so as to process the next re- 

35 ceived electronic mail resource. 

[0038] FIG. 5 is a flow diagram of electronic mail list 
display processing 500 according to an embodiment of 
the invention. The electronic mail list display processing 
500 is, for example, performed by the mobile device 200 

40 under the control of the electronic mail client application 
226 and the application program 202. 
[0039] The electronic mail list display processing 500 
begins with a decision block 502 that determines wheth- 
er a user has requested an electronic mail list. When a 

45 user has not requested the electronic mail list, the deci- 
sion block 502 causes the electronic mail list display 
processing 500 to be inactive. Once a user has request- 
ed the electronic mail list, then the electronic mail list 
display processing 500 is invoked. 

so [0040] Once evoked, a decision block 504 determines 
whether the electronic mail list is available from the per- 
sistent storage in the mobile device. For example, the 
electronic mail list will normally be stored in the persist- 
ent storage 206 of the memory 204. While it is anticipat- 

55 ed that in many cases the electronic mail list will be avail- 
able from the persistent storage due to the pre-loading 
(see FIG. 3), there are times in which the electronic mail 
list may not be available from the persistent storage. 
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Hence, when the decision block 504 determines that the 
electronic mail list is not available from the persistent 
storage, an electronic mail list request is sent 506 to the 
mail server. Then, a decision block 508 determines 
whether a response to the electronic mail list request 
has been received. The response to the electronic mail 
list request would include the electronic mail list from the 
mail server. When the decision block 50B determines 
that the response has not yet been received, the elec- 
tronic mail list display processing 500 awaits the recep- 
tion of the response. In one embodiment, the electronic 
mail list request is a synchronous request that causes 
the mobile device to await the reception of the requested 
resource before processing continues. Such synchro- 
nous requests are, for example, handled by the synchro- 
nous request manager 212 illustrated in FIG. 2. Once 
the decision block 508 determines that the response has 
been received, the received electronic mail list is stored 
510 in the persistent storage of the mobile device. Al- 
ternatively, when the decision block 504 determines that 
the electronic mail list is available from the persistent 
storage (due to pre-loading), then blocks 506-510 are 
bypassed. 

[0041] Following block 510, as well as directly follow- 
ing the decision block 504 when the electronic mail list 
is available from the persistent storage, the electronic 
mail list is retrieved 512 from the persistent storage. 
Next, the electronic mail list is displayed 514 to the user. 
At this point, the electronic mail list has been displayed 
to the user and the system thereafter waits for additional 
operations to be requested by the user. Following block 
514, the electronic mail list display processing 500 is 
complete and ends. 

[0042] FIG. 6 is a flow diagram of electronic mail op- 
erations processing 600 according to an embodiment of 
the invention. The electronic mail operations processing 
600 assumes that the electronic mail list is presently dis- 
played to the user of the mobile device (see FIG. 5). 
When the electronic mail operations processing 600 be- 
gins, an electronic mail options menu is displayed 602 
on the mobile device. The electronic mail options menu 
can be displayed concurrently or separately with the 
electronic mail list. Next, the electronic mail operations 
processing 600 effectively waits lor a user input that se- 
lects a particular electronic mail operation (function) to 
be performed with respect to the electronic mail list. 
These electronic mail operations include viewing, delet- 
ing, faxing, replying and creating electronic mail mes- 
sages. 

[0043] Once a user input has been entered, the elec- 
tronic mail operations processing 600 determines the 
particular electronic mail operation to be performed with 
respect to the electronic mail list. A decision block 604 
determines whether a view option has been selected. 
When the decision block 604 determines that the view 
option has been selected, view processing is performed 
606. On the other hand, when the decision block 604 
determines that the view option has not been selected, 
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a decision block 608 determines whether a delete option 
has been selected. When the decision block 608 deter- 
mines that the delete option has been selected, delete 
processing is performed 610 -When the decision block 
5 determines that the delete option has not been selected, 
then a decision block 612 whether a fax (facsimile) op- 
tion has been selected. When the decision block 612 
determines that the fax option has been selected, then 
fax processing is performed 614. When the decision 
10 block 61 2 determines that the fax option has not been 
selected, then a decision block 616 determines whether 
a reply option has been selected. When the decision 
block 616 determines that a reply option has been se- 
lected, then reply processing is performed 618. When 
75 the decision block 61 6 determines that the reply option 
has not been selected, a decision block 620 determines 
whether a new message option has been selected. 
When a decision block 620 determines that the new 
message option has been selected, new message 
20 processing is performed 622. When the decision block 
620 determines that the new message option has not 
been selected, a decision block 624 determines whether 
the user desires to exit the electronic mail operations 
processing 600. When the decision block 624 deter- 
25 mines that the user desires to exit the electronic mail 
operations processing 600, then the electronic mail op- 
erations processing 600 is complete and ends. On the 
other hand, when the decision block 624 determines 
that the user does not desire to exit the electronic mail 
30 operations processing 600. then the electronic mail op- 
erations processing 600 returns to repeat the decision 
block 604 and subsequent blocks so that user inputs 
with respect to electronic mail operations can be proc- 
essed. 

35 [0044] FIG. 7A is a flow diagram of view processing 
700 according to an embodiment of the invention. The 
view processing 700 is, for example, performed by the 
block 606 illustrated in FIG. 6. 
[0045] The view processing 700 initially identifies 702 
40 the selected message that is to be viewed. Typically, the 
user has acted to select one of the electronic mail mes- 
sages in the electronic mail list being displayed (see 
FIG. 5), and then to request to view the selected mes- 
sage. In one embodiment, the selected message is 
45 identified by a message identifier. Next, a decision block 
704 determines whether the message body associated 
with the selected message is stored in the persistent 
storage of the mobile device. When the message body 
is not stored in the persistent storage, a request for the 
so message body is sent 706 to the mail server. This re- 
quest for the message body is thus sent over the wire- 
less data network to the mail server. Hence, when the 
network is unavailable to the mobile device, the request 
cannot be successfully transmitted and delays can oc- 
cur. Following block 706, a decision block 708 deter- 
mines whether a reply to the request for the message 
body has been received from the mail server. When the 
decision block 708 determines that the reply (the mes- 
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sage body) has not yet been received from the mail serv- 
er, the view processing 700 awaits the arrival of the re- 
ply. Once the decision blocks 708 determines that the 
reply (including the message body) has been received, 
the reply is stored 710 in the persistent storage of the 
mobile device. In one embodiment, the synchronous re- 
quest manager 212 illustrated in FIG. 2 transmits the 
request and receives the reply from the mail server 
[0046] Alternatively, the blocks 706 through 7 1 0 of the 
view processing 700 are able to be bypassed when the 
decision block 704 determines that the message body 
already resides in the persistent storage of the mobile 
device. Thus, when the persistent storage has been pre- 
loaded to include the message body (i.e., a resource of 
the electronic mail channel) that is desired, the view 
processing 700 can operate without regard to network 
availability, and thus without network delays. 
[0047] Following block 71 0, as well as directly follow- 
ing the decision block 704 when the message body is 
found within the persistent storage, the message body 
for the selected message is retrieved 712 from the per- 
sistent storage. The retrieved message body is then dis- 
played 714 on the display device of the mobile device. 
Following block 714, the view processing 700 is com- 
plete and ends. 

[0048] FIG. 7B is a flow diagram of an optional en- 
hancement to the view processing 700 according to an 
embodiment of the invention. The enhancement per- 
tains to message marking processing 750 that can be 
performed between the block 712 and 714 of the view 
processing 700 illustrated in FIG. 7A. The message 
marking processing 750 allows the mobile device to 
asynchronously (i.e., background process) inform the 
mail server of those messages that have been read. The 
message marking processing 750 initially determines at 
decision block 752 whether the selected message has 
already been read. If the selected message has not al- 
ready been read, then the message is marked as having 
been read because the message is displayed in block 
71 2 for the user to read the message. After marking the 
message (i.e., the local copy) as being read, a message 
read request is placed 756 in the asynchronous mes- 
sage queue. The message read request will serve to in- 
form the mail server that a particular message has been 
read, and thus allow the mail server to keep track of 
those message the user has read. 
[0049] FIG. 8 is a flow diagram of the delete process- 
ing 800 according to an embodiment of the invention. 
The delete processing 800 is, for example, performed 
by block 610 illustrated in FIG. 6. 
[0050] The delete processing 800 initially identifies 
802 a selected message to be deleted. Typically, the us- 
er has acted to select one of the electronic mail mes- 
sages in the electronic mail list being displayed (see 
FIG. 5), and then to request to delete the selected mes- 
sage. Next, a decision block 804 determines whether 
the user has confirmed the deletion of the selected mes- 
sage. When the user does not confirm the deletion of 



the selected message, the delete processing 800 is 
complete and ends because the user has not confirmed 
its deletion. On the other hand, when the decision block 
804 determines that the user has confirmed the deletion 

s of the selected message, then the selected message is 
deleted 806 from the persistent storage. The electronic 
mail list is then retrieved 808 from the persistent storage. 
The electronic mail list is retrieved 806 from the persist- 
ent storage so that an updated electronic mail list is pro- 

10 vided. The retrieved electronic mail list is then displayed 
810 to the user. As an example, with respect to the mo- 
bile device 200 illustrated in FIG. 2, the electronic mail 
list can be displayed on the display device 228. Addi- 
tionally, a delete message request is placed 812 in an 

'5 asynchronous request queue. For example, with re- 
spect to FIG. 2, the delete message request can be cre- 
ated by the electronic mail client application 226 and for- 
warded by the application program 202 to the asynchro- 
nous request queue 220. Thereafter, the asynchronous 

20 request manager 216 can process the delete message 
request by sending it to the mail server when the net- 
work is available so that the mail server can update its 
database of messages. Following block 612. the delete 
processing 800 is complete and ends. 

25 [0051] FIG. 9 is a flow diagram of fax processing 900 
according to an embodiment of the invention. The fax 
processing 900 is ; for example, performed by the block 
614 illustrated in FIG. 6. 

[0052] The fax processing 900 initially identifies 902 

30 a selected message to be sent by facsimile. Typically, 
the user has acted to select one of the electronic mail 
messages in the electronic mail list being displayed (see 
FIG. 5), and then to request to transmit the selected 
message to a facsimile machine. A facsimile option 

35 screen is then displayed 904. The facsimile option 
screen allows a user to enter a destination information 
for a facsimile to be sent. The facsimile to be sent in- 
cludes the contents of the selected message. Next, a 
user enters 906 the destination information which, for 

40 example, would include a facsimile telephone number 
and any suitable cover letter. A decision block 908 then 
determines whether the user has confirmed and re- 
quested to send the facsimile. When a decision block 
908 determines that the user has not confirmed and re- 

45 quested to send the facsimile, the fax processing 900 
awaits the user's confirmation and permits the user to 
alter the destination information. On the other hand, 
when the decision block 908 determines that the user 
has confirmed and requested to send the facsimile, a 

so confirmation that the facsimile was sent is displayed 
910. Additionally, a facsimile request is placed 912 in an 
asynchronous request queue. For example, with re- 
spect to FIG. 2, the facsimile request can be generated 
by the electronic mail client application 226 and forward- 

ss ed by the application program 202 to the asynchronous 
request queue 220. Thereafter, the asynchronous re- 
quest manager 216 can send the facsimile request to 
the mail server when network availability permits. Fol- 
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lowing block 912, the facsimile processing 900 is com- 
plete and ends. 

[0053] FIG. 10 is a flow diagram of reply processing 
1000 according to an embodiment of the invention. The 
reply processing 1000 is, for example, performed by 
block 618 illustrated in FIG. 6. 
[0054] The reply processing 1000 initially identifies 
1002 a selected message that is to be replied to. Typi- 
cally, the user has acted to select one of the electronic 
mail messages in the electronic mail list being displayed 
(see FIG. 5), and then to request to reply to the selected 
message. A reply screen is then displayed 1004. Next, 
the user then enters 1006 a reply message using the 
reply screen. Then, a decision block 1008 determines 
whether the user has requested to send the reply mes- 
sage. When the decision block 1 008 determines that the 
user has not yet requested to send the reply message, 
the reply processing 1000 awaits the users request to 
send the reply message and permits the user to alter 
the reply message. Once the user has requested to 
send the reply message, a confirmation that the mes- 
sage was sent is displayed 1010. Additionally, a reply 
message request is placed 1 01 2 in an asynchronous re- 
quest queue. For example, with respect to FIG. 2, the 
reply message request can be generated by the elec- 
tronic mail client application 226 and forwarded by the 
application program 202 to the asynchronous request 
queue 220. Thereafter, the asynchronous request man- 
ager 216 can send the reply message request to the mail 
server when network availability permits. Following 
block 1012. the reply processing 1000 is complete and 
ends. 

[0055] FIG. 11 is a flow diagram of new message 
processing 1 1 00 according to an embodiment of the in- 
vention. The new message processing 1100 is, for ex- 
ample, performed by block 622 illustrated in FIG. 6. 
[0056] The new message processing 1100 initially 
displays 1102 a message recipient screen. A user then 
enters 1104 a recipient into the message recipient 
screen. Next, a message subject screen is displayed 
1106. A user then enters 1103 a message subject into 
the message subject screen. Next, a message body 
screen is displayed 1110. A user then enters 1112 a 
message body into the message body screen. Following 
block 1 1 1 2, a decision block determines whether the us- 
er has requested to send the new message. When the 
user has not yet requested to send the message, the 
new message processing 1100 can return to repeat any 
of the prior blocks 1102-1112 so as to alter any previ- 
ously entered information concerning the newmessage. 
On the other hand, once the decision block 1114 deter- 
mines that the user has requested to send the message, 
then a confirmation that the new message was sent is 
displayed 1116. Additionally, a new message request is 
placed 11 18 in an asynchronous request queue. For ex- 
ample, with respect to FIG. 2, the new message request 
can be generated by the electronic mail client applica- 
tion 226 and forwarded by the application program 202 



to the asynchronous request queue 220. Thereafter, the 
asynchronous request manager 216 can send the new 
message request to the mail server when network avail- 
ability permits. Following block 1118, the new message 

5 processing 11 00 is complete and ends. 

[0057] The asynchronous transmissions from the mo- 
bile device to the remote server (e.g., mail server) ena- 
ble the mobile device to continue processing while these 
asynchronous transmissions occur in the background. 

10 Additionally, asynchronous reception (referred to as 
"push") can also occur in the background. Asynchro- 
nous transmissions are described further below with re- 
spect to FIG. 12, and asynchronous receptions are de- 
scribed further below with respect to FIG. 13. 

75 [0058] Although not shown in FIG. 6, the electronic 
mail operations processing 600 can also include locking 
and unlocking electronic mail messages as another 
electronic mail operation. When a user interacts with the 
mobile device to "lock" a particular electronic mail mes- 

20 sage in an electronic mail list, the particular electronic 
mail message will remain locally stored and available in 
the persistent storage. In contrast, when an electronic 
mail message is not locked, it can be bumped out of the 
persistent storage to make room for a newer electronic 

25 mail message. A locked electronic mail message will re- 
main in the persistent storage until deleted. Typically, 
the particular electronic mail message is locked by a us- 
er selecting a "lock" menu option when the electronic 
mail list is displayed on the display device. For visual 

30 feedback and notification, once a electronic mail mes- 
sage is locked, a distinctive icon can be displayed next 
to the electronic mail message in the electronic mail list. 
[0059] Additionally, to facilitate easy entry of informa- 
tion into the various data entry screens for reply mes- 

35 sages, fax destination information or new message in- 
formation, one or more lists of most recently used data 
can be maintained (e.g., on the mobile device). A user 
is then able to enter the data for data input screen by 
selecting an entry in the appropriate list of most recently 

40 used data. For example, in FIG. 11, with respect to block 
1 1 04, a recent recipient list could be available to the user 
so that the user merely selects an entry in the recent 
recipient list without having to identify the recipient and 
their electronic mail address. Similarly, in FIG. 9, with 

45 respect to block 906, a recent facsimile numbers list 
and/or a recent recipient list could be available to the 
user for easy entry of data. In one embodiment, the 
number of entries stored in the list is small (e.g., 5-10) 
because of memory consumption and screen sizes with 

so mobile devices. In any case, the entries in the various 
most recently used lists can be locked so that they are 
not removed from the lists. 

[0060] FIG. 1 2 is a flow diagram of asynchronous re- 
quest send processing 1200 according to an embodi- 
es ment of the invention. The asynchronous request send 
processing 1 200 is, for example, performed by the asyn- 
chronous request manager 216 illustrated in FIG. 2. 
[0061] The asynchronous request send processing 
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1 200 begins with a decision block 1 202 that determines 
whether a wireless network is available to the mobile 
device. Wireless networks often have sporadic connec- 
tivity or high latency due to out-of-range, congestion, 
etc. and thus are temporarily unavailable to mobile de- s 
vices. When the decision block 1 202 determines that the 
wireless network is not available, then the asynchro- 
nous request send processing 1200 simply awaits the 
availability of the wireless network. Once the wireless 
network becomes available, then a decision block 1204 
determines whether an asynchronous request queue is 
empty. The asynchronous request queue is within the 
mobile device and is : for example, the asynchronous re- 
quest queue 220 illustrated in FIG. 2. 
[0062] When the decision block 1 204 determines that 
the asynchronous request queue is empty, then the 
asynchronous request send processing 1 200 returns to 
repeat the decision block 1202 and subsequent blocks 
because there is presently no requests waiting to be 
processed in the asynchronous request queue. On the 
other hand, when the asynchronous request queue is 
not empty, then an entry in the asynchronous request 
queue that is to be sent is selected 1206. The selected 
entry in the asynchronous request queue is then sent 
1208 to a server via the wireless network. The server 
can be a proxy server or a remote server (e.g., mail serv- 
er) on a remote network. Typically, according to the in- 
vention, the selected entry is a request for a electronic 
mail resource located at a mail server on the remote net- 
work. 

[0063] After sending the selected entry to the server, 
a decision block 1210 determines whether a send error 
has occurred. In other words, the decision block 1210 
waits for an acknowledgment that the server has re- 
ceived the selected entry that has been sent. When the 
decision block 1210 determines that no send error oc- 
curred during the sending of the selected entry to server, 
then the selected entry is removed 1212 from the asyn- 
chronous request queue. On the other hand, when the 
decision block 1210 determines that a send error has 
occurred, a decision block 1214 determines whether a 
retry is desired to resend the selected entry to the server. 
When the decision block 1214 determines that a retry is 
desired, then processing returns to repeat the block 
1208 and subsequent blocks. Alternatively, when the 
decision block 1214 determines that a retry is not de- 
sired, then processing proceeds to the block 1212 
where the selected entry is removed 1212 from the 
asynchronous request queue. Following block 1212, the 
asynchronous request send processing 1200 returns to 
repeat the decision block 1 202 and subsequent blocks 
so that additional entries in the queue can be processed. 
[0064] FIG. 13 is a flow diagram of server push 
processing 1300 according to an embodiment of the in- 
vention. The server push processing 1300 is, for exam- 
pie, performed by a network gateway (or proxy server) 
such as the network gateway 106 illustrated in FIG. 1. 
[0065] The server push processing 1 300 begins with 



a decision block 1302. The decision block 1302 deter- 
mines whether the network is available. Here, the deci- 
sion block 1302 is determining whether a wireless con- 
nection from the network gateway through the wireless 
network to the appropriate mobile device is available. 
When such network is not available, the server push 
processing 1 300 is not evoked and merely awaits the 
availability of the network. When the network is availa- 
ble, a decision block 1304 determines whether a push 
queue is empty. The push queue contains resources (or 
replies to requests) that had been previously issued by 
the mobile device. In the case of electronic mail, the re- 
sources or replies to requests temporarily stored in the 
push queue are electronic mail resources. When the de- 
cision block 1304 determines that the push queue is 
empty, then there are no resources to be transmitted 
from the network gateway to the mobile device and thus 
the server push processing 1300 returns to repeat the 
decision block 1 302 and subsequent blocks. 
[0066] On the other hand, when the decision block 
1304 determines that the push queue is not empty, then 
a resource in the push queue is selected 1 306 to be sent 
to the mobile device. Then, the selected resource is sent 
1308 to the mobile device. Following block 1308, the 
server push processing 1300 returns to repeat the de- 
cision block 1 302 so that additional push requests can 
be forwarded to the mobile device. At the mobile device, 
the resources pushed are received and managed by a 
push manager, such as the push manager 222 illustrat- 
ed in FIG. 2. 

[0067] In one embodiment, the resources (e.g., elec- 
tronic mail resources) stored in the push queue are lim- 
ited in size. The resources can be limited in size anytime 
prior to being sent 1 308 to the mobile device. For exam- 
ple, the mail server or the network gateway can operate 
to limit the size of the electronic mail resources. As an 
example, the size of the electronic mail resources can 
be limited to a predetermined maximum size. The max- 
imum size can be set by the network gateway, the mail 
server, or the mobile device. While normally fixed, the 
maximum size could also be dynamically changed. In 
one exemplary embodiment, 400 bytes has been used 
as a maximum size. Then, once the electronic mail re- 
sources are sent 1308 to the mobile device they do not 
consume a large portion of the memory (namely, per- 
sistent storage) because they are of limited size. By lim- 
iting the electronic mail resources, the memory of the 
mobile device is able to store more electronic mail mes- 
sages (which are ol the limited size). Hence, the mem- 
ory of the mobile device (which itself is of limited capac- 
ity) is intelligently used. 

[0068] Typically, the limiting operates to limit the size 
of the message bodies. Thus, when a user views a mes- 
sage body only the first portion of the message body is 
initially displayable to the user. When there is additional 
portions of the message body, the user can be informed 
via the display screen that additional portions can be re- 
quested. If the user requests a next portion, then a syn- 
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chronous request for the next portion is sent to the mail 
server and the next portion of the message body is 
thereafter received and displayed. Again, the next por- 
tion can also be of limited size. Additionally, a percent- 
age of the portion of the total message that has been s 
read can be displayed on the display screen for the user. 
The percentage would increase with each next portion 
read until all (100%) of the message is read. 
[0069] FIG. 14 is a block diagram of a mobile device 
1 400 according to another embodiment of the invention, to 
Like the mobile device 200 illustrated in FIG. 2, the mo- 
bile device 1400 is particularly suited for wireless com- 
munications through a wireless network where connec- 
tivity is sporadic or high-latency conditions are present. 
[0070] The mobile device 1400 includes an applica- is 
tion 1402 that couples to a cache memory 1404 through 
an interface 1406. The application 1 402 is, for example, 
a network browser application that allows a user of the 
mobile device 1400 to request and receive resources 
provided on a remote nelwork (e.g., Internet) that the 20 
mobile device 1400 is able to communicate with. The 
cache memory 1404 stores resources that have been 
previously requested and received by the mobile device 
1400. Additionally, the cache memory 1404 can be used 
to store various channels and lists that are used to irn- 25 
prove performance of the mobile device 1400. 
[0071] The mobile device 1400 also includes a syn- 
chronous request manager 1 408 and an asynchronous 
message manager 1410. The synchronous request 
manager 1408 manages the synchronous sending and 30 
receiving of messages with respect to the remote net- 
work a wireless communication link 1409. The asyn- 
chronous message manager 1410 manages the asyn- 
chronous sending of messages with respect to the net- 
work via a wireless communication link 1411. The asyn- 3S 
chronous message manager 1410 is provided so that 
the mobile device 1400 can communicate with the re- 
mote network in an asynchronous manner. The ability 
of the mobile device 1400 to communicate in an asyn- 
chronous manner is particularly useful in cases where 40 
the wireless network has high-latency conditions or suf- 
fers from sporadic connectivity. 
[0072] The asynchronous message manager 1410 
connects to an asynchronous message queue 1 41 2 that 
stores messages that are to be sent to the remote net- 45 
work via the asynchronous message manager 1410 and 
the wireless communication link 1411. In general, the 
messages awaiting transmission to the remote network 
remain in the asynchronous message queue 1412 until 
the asynchronous message manager 1 410 determines so 
that the wireless network is available, and then pro- 
ceeds to service the particular messages stored in the 
asynchronous message queue 1412 such that they are 
sent to the remote network through the wireless com- 
munication link 1411 of the wireless network when the ss 
wireless network is available. 

[0073] The push manager 1414 receives pushed 
messages (e.g., resources) from the remote network 
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over a wireless communication link 1 41 5. These pushed 
messages that are received by the push manager 1414 
over the wireless communication link 1415 are either in 
response to requests that have been asynchronously 
sent by the mobile device 1400 or provided ("pushed") 
by a remote server to the mobile device 1400 connects 
via the wireless network. 

[0074] The mobile device 1 400 also includes a chan- 
nel manager 1416 and a list manager 1418. The channel 
manager 1416 operates to load certain content chan- 
nels into the cache memory 1404 of the mobile device 
1400. According to the invention, one pertinent content 
channel is an electronic mail channel, which includes 
electronic mail resources associated with providing 
electronic mail services the mobile device 1400. The 
content channels are loaded into the cache memory 
1 404 by the channel manager 1 41 6 so that the perform- 
ance of the mobile device 1 400 is improved with respect 
to the particular content associated with the content 
channels loaded in the cache memory 1404. In particu- 
lar, should a user of the mobile device 1400 request (via 
the application 1402) a resource associated with a con- 
tent channel stored in the cache memory 1 404, then the 
requested resource can be rapidly supplied to applica- 
tion 1 402 via the cache memory 1 404. Otherwise, when 
a requested resource is not found in the cache memory 
1404, the availability of the requested resource at the 
mobile device is relatively slow because the request 
must be sent to either the synchronous request manag- 
er 1408 or the asynchronous message manager 1410 
to obtain the resource from a remote server located on 
the remote network. 

[0075] The list manager 1418 operates to store one 
or more lists in a memory 1420 (e.g., random-access 
memory). The lists that are stored in the memory 1420 
are used to enable the list manager 1418 to manipulate 
various lists that are used by user interfaces associated 
with the application 1402. The user interfaces operate 
to display the various lists on a display 1422. Such lists 
are thus able to be modified locally within the mobile de- 
vice 1 400 without the need for availability of the wireless 
network. According to the invention, one pertinent list 
that is managed by the list manager 1 41 8 is an electron- 
ic mail list that is displayed in the display 1422 and able 
to be locally modified without regard to network availa- 
bility. The memory 1420 can also store resources from 
the remote network that are used toconfigure or operate 
the mobile device 1400. 

[0076] The advantages of the invention are numer- 
ous. Several advantages that embodiments of the in- 
vention may include are as follows. One advantage of 
the invention is that electronic mail services can be per- 
formed on electronic mail messages even when the net- 
work is unavailable. Clients, e.g., mobile devices, are 
able to perform electronic mail services regardless of 
network availability. As a result, clients experience bet- 
ter responsiveness and less waiting. Another advantage 
of the invention is that a mail server located on the net- 
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work is able to be kept current by use of asynchronous 
messaging. 

[0077] The many features and advantages of the 
present invention are apparent from the written descrip- 
tion, and thus, it is intended by the appended claims to 
cover all such features and advantages of the invention. 
Further, since numerous modifications and changes will 
readily occur to those skilled in the art, it is not desired 
to limit the invention to the exact construction and oper- 
ation as illustrated and described. Hence, all suitable 
modifications and equ ivalents may be resorted to as fall- 
ing within the scope of the invention. 

Claims 

1. A mobile device for use with a wireless data com- 
munication network, said mobile device compris- 
ing:- 

a memory storage device that stores electronic 
mail resources; 

an electronic mail processor that performs an 
electronic mail operation with respect to the 
electronic mail resources stored in said memo- 
ry storage device, and wherein the electronic 
mail operation can be carried out at said mobile 
device even when the wireless data communi- 
cation network is not available to said mobile 
device; and 

a display device that displays at least a part of 
one or more of the electronic mail resources. 

2. A mobile device as recited in claim 1 wherein the 
storage of the electronic mail resources in said 
memory storage device is persistent and thus not 
subjected to cache removal processing. 

3. A mobile device as recited in claim 1 or 2 wherein 
in performing the electronic mail operation, said 
electronic mail processor modifies the electronic 
mail resources stored in said memory storage de- 
vice in accordance with the electronic mail opera- 
tion being performed. 

4. A mobile device as recited in claim 3 wherein said 
mobile device further comprises: - 

an asynchronous message queue and an 
asynchronous message manager operatively con- 
nected thereto, wherein said asynchronous request 
queue stores outgoing asynchronous messages to 
be sent from said mobile device to a mail server 
coupled to said wireless communication network. 

5. A method for interacting with electronic mail mes- 
sages on a mobile device, the mobile device being 
able to communicate with a mail server at least in 
part through a wireless data network, said method 
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comprising:- 

pre-loading electronic mail message resources 
into a storage device of the mobile device: 
5 receiving a request to view an electronic mail 

list; 

determining whether the electronic mail list is 
available from the storage device of the mobile 
device: 

10 receiving the electronic mail list from the stor- 

age device when the electronic mail list is de- 
termined to be available from the storage de- 
vice of the mobile device: 
requesting and subsequently receiving the 

1$ electronic mail list from the mail server when 

the electronic mail list is determined not to be 
available from the storage device of the mobile 
device; and 

displaying the received electronic mail list. 

20 

6. A method as recited in claim 5 wherein the availa- 
bility of the wireless data network to the mobile de- 
vice is sporadic, and 

wherein when the electronic mail list is avaii- 
25 able from the storage device, the received electron- 
ic mail list can be displayed regardless of the avail- 
ability of the wireless data network to the mobile de- 
vice. 

30 7. A method for interacting with electronic mail mes- 
sages on a mobile device, the mobile device being 
able to connect to a remote mail server through a 
wireless data network, said method being per- 
formed by said mobile device and comprising:- 

35 

displaying an electronic mail list on a display 
screen of the mobile device, the electronic mail 
list including one or more entries that identify 
particular electronic mail messages; 
40 selecting one of the entries of the electronic 

mail list being displayed on the display screen 
of the mobile device; 

performing an operation on the electronic mail 
message associated with the selected entry 

^5 without delay due to the unavailability of the 

wireless data network to the mobile device; and 
asynchronously sending a notification to the re- 
mote mail server based on the operation per- 
formed on the electronic mail message associ- 

50 ated with the selected entry when the wireless 

data network is available to the mobile device. 

8. A method as recited in claim 7 wherein when the 
operation performed on the electronic mail mes- 
55 sage requires the electronic mail list to be updated, 
the electronic mail list is re-displayed in its modified 
form without regard to whether the wireless data 
network is available to the mobile device. 
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9. A computer readable medium including computer 
program code for interacting with electronic mail 
messages on a computing device, the computing 
device being able to communicate with a mail serv- 
er at least in part through a data network, said com- 5 
puter readable medium comprising: - 



computer program code configured to pre-bad 
electronic mail message resources into a stor- 
age device of the computing device; 10 
computer program code configured to receive 
a request to view an electronic mail list; 
computer program code configured to deter- 
mine whether the electronic mail list is available 
from the storage device of the computing de- is 
vice; 

computer program code configured to receive 
the electronic mail list from the storage device 
when the electronic mail list is determined to be 
available from the storage device of the com- 20 
puting device; 

computer program code configured to request 
and subsequently receive the electronic mail 
list from the mail server when the electronic 
mail list is determined not to be available from 25 
the storage device of the computing device; 
and 

computer program code configured to display 
the received electronic mail list. 

30 

10. A computer readable medium for interacting with 
electronic mail messages on a computing device, 
the computing device being able to connect to a re- 
mote mail server through a data network, said com- 
puter readable medium comprising:- 35 

computer program code configured to display 
an electronic mail list on a display screen of the 
computing device, the electronic mail list in- 
cluding one or more entries that identify partic- *o 
ular electronic mail messages: 
computer program code configured to select 
one of the entries of the electronic mail list be- 
ing displayed on the display screen of the com- 
puting device; 45 
computer program code configured to perform 
an operation on the electronic mail message 
associated with the selected entry without de- 
lay due to the unavailability of the wireless data 
network to the computing device; and $0 
computer program code configured to asyn- 
chronously send a notification to the remote 
mail server based on the operation performed 
on the electronic mail message associated with 
the selected entry when the data network is ss 
available to the computing device. 
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Description EP 0 994 6 °S A2 

BACKGROUND OF THE INVENTION 

1. Field of the Invention 

2. Description of the Related Art 

browsers so that users are able to requeS eEo2? T a n 3 ma " server that interacts with users' network 

&*T a T wha ^ Trt ^^^o^)"2S? wNch are performed by the mai « 

-relels network 1^2^?^^'^^ 5T imP ' emented ° V6r ^ ed as we,, as 

is .n communication with the mar, server Si " client all?"' 6 ' f d,ent app,ication < e 9 • network browser! 

«Iy muS e Cn" avr^?;~ J *- - opera«on of Cent applications 

client apportions can become "hung" namely s*oDD?no furthir When the network is unavailable the 

the network is received. The network can be a S nll^ u P rocess,n 9 untrt a response from a remote server via 

mob e dev.ce (supporting the client applicat on)' exceed ?o if* netWOrk can result frof " a user of a 

effectively results from a wireless network hZ h^h iL t 9 9eographic range of coverage. Unavailability also 
failure Because of the dependent he o^Son ^ T^T^ C0 ™ e <*^ h» congS otl™ 
applicabons often have to wait for resources 12 ma° server Th?^ 0 "? «° n the availabiii * of net w°*s. clS 
SS5S 18 UnaVai ' ab,e t0 the dient aPP«cations ^ Th6Se Wart t,mes are ""acceptably long when the 

rented an^S^o^ « - temporarily store previous, 

the computers or mobile devices on netwo/k TvailS' Hn™ ™ emor y' s helpful in reducing the dependency of 
requested resource happens to reside «Xec^^^l ™n,ory is only helpful when the newly 

requested, then the newly requested rel»uS vS^iS^rt . 1 i * e newhr guested resource was not prevtousS 
requested resource were at o°e pZ ^ZstStZ SrS"* ^ C3Che memory - Also - even ?f 

g^V h and-he,d ^^5^^ to^ 

S device ^.S^JJ^ 3 " etW ° rk br0WSCr « o" *• computer or 

Since the network browsers often r^^Z"'^™™™ residin 9 °" a mail server over the Internet 

aenfeet with a mail server across a network ' f3Ced by users seekin 9 *> Perform electronic mail 



SUMMARY OF THE INVENTION 
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manaoes the electronic m.l serAes aS cfenTSJlEe to TSSJS ""r"*; »» mail save, eent„ll» 



2- 



anap Parat da se ^ 

incJes: a ^2^^^^^^.?^"^ M emb ° diment ° f the in ^ion 

an electronic mail operation with respect to the SSnTc maiZ^.^ I" "If*™ ma " PrOCessor that P erforms 
where the electronic mail operation can be carrK i sa^ Sa ' d mem0fy device - and 

communication network is not available to sa* mobile device an?* j£f ^ ^ n when the wire,ess data 
one or more of the electronic mail resources " 3 d ' Splay dev,ce that dis P |avs at least a part of 

commira,?^ .STp^J tl^ °^ 3 "?* "» «* **« bei " 9 

invention includes the acts of: pre-loading "oKita mai mSS„f » ^ netWOrk - an em bodiment of the 
device, receiving a request to view an eZSc mi Z 9 ,L 0UfCeS "l to a s,0ra 9 e device of the mobile 
available from the storage device of tli n^^Z^I^^^ 9 the e,eCtronic mail list is 

when the electronic mail list is determined tob!SSSie^7^ T° ma " " St from the stora 9e device 
and subsequently receiving the electronic m^il fef from thl ^i 39 ! deV ' Ce of the mobile device; requesting 

not to be available from the 'storage deSofX mo^di^ ^.^^ the eleCtf ° niC mail ,ist is determined 
[0013] As a method for interacts wrth plZrS 1 ■ d,s P |a y n 9 tne received electronic mail list, 
awe to connect to a remote IS^I^S^ZZS^^ I ** ^ device bein 9 

displaying an electronic mail list on a dispL ^screen o the mnh^ H " T b °? ment 0f the invention incl "des 
or more entries that identify particular electronic mTm?J£L f*™ 6 ' the electronic ™il fet including one 
l.st being displayed on the i^J^i^JS^SS^S^ ° f *" ^ ° f the e,ectroni " ma ' 
message associated with the selected entry without £52 £ fo th! ,?n 9 SI ° per f on on the e,ectronic ™' 
the mobile device; and asynchronously send^g a nofificafon to £ r^^, ° f the Wireless data netw °rk to 

aKSerob^s 

Seiages on*. loZZ^e^Z^ S^'SSZ"*" ^ "«"*> - 

through a data network, an embodiment of the invention a mail server at least in part 

electronic mail message resources into riorage dS Pr ° 9fam COde confi9ured to P' e -'<>ad 

receive a request to view an electronic mail lis^co^ 

electronic mail list is available from the storage device of me coZf^„ C H 6 confi 9 ured to de t*™ne whether the 
to recerve the electronic mail list from th! storage dJKe^SS? C ° mpU ^ , pr ° 9ram Configured 

available from the storage device of the comS, £XZ , \ 6 electronic ma" *« is determined to be 
subsequently receive the 9 electronic ma3 list fTom ^e ma^e^eT when P thf ?"? C ° n f 9ured t0 re « uest and 
SctLTSoSS^ 

invention includes: computer program code SStodtaT.!? 3ta netWork ' an embodiment of the 
computing device, the electronic mail fet incSno one Til f?™! ?t ' iSt 0n 3 dis P |a V screen of the 
messages; computer program code cnZirttort^nfat^J^T If- P3rticU,3r elec,ronic mail 
on the display screen of the computing device- wmD^ ^JJ. ^ r' he elec,romc mail list bein 9 displayed 
electronic mail message associated wrth ^selected en£ S ^ H^r t0 perform an °P era «on on the 
network to the computing device; and computer^ ogram code Ll£?M l ° unavai,abili, y of the wireless data 
remote mail server based on the operation performed on the tecS 1?^'°™^ Send a notification to the 
So7eT en da<a netW ° rk iS 3Vailable t0 comMng Sevice meSS39e associated w «h the selected 

Lei are^ ToT'o* ^^oTJZL Wj - ^ ** emb ° dimentS °' the inventi °" ma * 
e ectronic mail messages even when the n^T2^*c£^ ™" f™ 65 ^ perf ° rmed on 
electron* mail services regardless of n^ m ^e^m f ^ a ( ^S' ^'"l 3re ab ' e t0 P 8 " 0 ™ 

and less wartrng. Another advantage of the invention is Zt a m*. L? n ' , ?1 ex P enence bett er responsiveness 
current by use of asynchronous mBssi^ ^SS^S^t^^ ° n ^ netWOrk is ab,e to be 
he memo^ c-ients whic^ Ire being Sn^ttLSCT ma " a9ement * 

3, description, taken in ^ncS JSTJllcc^ ^ the f0,,0 ^ n9 deteiled 

50 of the invention. 6 accom P an y n 9 drawings wh IC h illustrate, by way of example, the principles 

BRIEF DESCRIPTION OF THE DRAWINGS 

FIG. 1 . , b,„ ck <, iagram 0 , . ^ aate amnMfc , ta „ ^ accor()ing B ^ embM|ment ^ 
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FIG. 3 is a flow diagram of electronic mail channel processing; 
5 ^^^^^^^^^^^^^^ 

» F,G - 7AlSaflow ^^ 

FIG. 8 is a flow diagram of delete processing according to an embodiment of the invent 
FIG. 9 ,s a flow diagram of fax processing according to an embodiment of the invention 
FIG. 10 is a flow diagram of repry processing according to an embodiment of the invent 
F.GHisaflowdiagram of new message processing according to an embodiment of the invention- 
's a flow diagram of asynchronous re q uestsend processing according to an embodiment the invention- 

F.G. 14 is a block diagram of a mobile dev.ce according to another embodiment of the invention. 
DETAILED DESCRIPTION OF THE INVENTION 

Elver a^d t^^^^Strni: T^ 9 - ~*- «*~ * network A 

electronic mail services, clients ar "S? t! ^SL^^^SS^ *• mail server centrally manages tht 
network ,s unavailable. Accordingly clie^ S3dn^iIf^# Pe,fon ? CertB,n etec^fc mai seivices whS tt!I 
s|gntont delays when the network 9 LnavaLr^ mail s «™<* no S^Tt^Si 

of reasons, including: congestion, out of rSe ne^SL ' east tem P° rari| y unavailable for a variS 

invention is particularly well suited for network Ifz^Zil 1 6tC The network can be wired or wirelL The 
(0020J While the invention is J^bS^SSl^JZ!^ IF" " eXC6SSive tra * c 

reference to a wireless communication system sin^e ll, ^eless networks, the invention is described below with 
wireless communication system, a wireteS neS KEL M * m ° re often suffer netw °* unavailabl e In a 
plurality of mobile devices to a wire Tnetork mS nl "'"^ netWOfk) gene,al, y su PP°ts oonSSon of a 
nefcvork to request and receive various ^S U rc es The^r?!!!lT mun L Cate se ^r machines on the v2ed 

oata coromumcaton system 100 supports a larae numh., i?^?^ e ae " ces 102 8nd 104 Normal,, the vweless 
are representative of the mobile de*es™siTese Shi. %?"^ ar "" hU5 *« 1 02 an™ M 

^ough ageless network 108, The *SkSew£l£ S?3L? '°l can cou|,le " > a gafeZ ,™ 

M XT™,™ 8 ""T 0 * 3atewa ' 106 * «• l« excharSnSSSh ^"' M 'V 8 3 p,<>x > se ~ e ' °' ^«es?oaia 

network gateway 106 and the mai. se'rveM 'ote HTTPse^" emb ° d,ment ' 1 12 is ^St'Te 

rnai, s erver . S^^^SZZ ™™ZoT '** ™™ ™° ^ored on, on the 

electronic mail operations, such as^ieS I dJtefinS ^* c ™ m Tf^ ^ * e ™ B order to perform 

™reo _ afa) sterns v-here to. c° m »» JEMcSBJT. S H 
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eec romc mail is received, the list would be displayed to a use? £" Ce the request ,ist <> 

electron* mail operations on one of the listed electronic mail m^Ll u C ° U ' d then perform one ° f the 
were all performed by the mail server and I thus neS l! i,T 3 H ° WeVer ' the ele ctronic mail operations 

5 to delete a certain message from vS^MaSS^ZT^^ W3S "T^ For example - ff a user guested 
he network was unavailable, the reques woul hSTSleSnd "T^ T M be sent t0 the mail s ^er. If 
for the network availability to return or Tent"! ^ & ^ ™^ ^ ™* 

receded at the mail server, the mail server would proces X rflt J , ( m . ach,ne) wou,d 9ive up. Once 

mail for the mobile device (or local ma^e^he mSd 1st rt fJ^ a " d the " modify the list of electronic 

to *«™ <°' '°ca. machine), again requiring network avSaSty C,r ° n ' C ma " W ° U ' d then be sent t0 tne mobile 

fajurel. etc., ^ ^ ^ ^on, obstructs, network 

During such network unavailability, conventional ^Sn^rt SEJ^L t0 dev,ces (or local machines) 

machines) to complete electronic mail operaSs Ofte tSs caused? Ik? 0 ?' 1 ^ mobi,e machines 
delays wh,ch are unsatisfactory to the users of the mobile 2E£Yn,£ 0b f e d6V f e (or local macnine ) to incur 
approaches to providing electronic mail to local devtceTa e uSSLSJ^?' macn,n ? s >- Thus . the conventional 
not available to the mobile devices, the mobile devices ^are no a hiP to n^I 7 Namely ' when the wireless network is 
0025] According to the invention ^ ^^1 «~ e ° perform any e,e ctronic mail functions. 
^ctionseventhough^Ue^ \T "?* <0 Perf0rm many el « c «* 

&r m e ob» 

1. The mobile device 200 is partii^lEd^ device . 1 ° 4 Crated in FIG. 

connectovrty is sporadic or high-latency condieonrare pre^enf COmmun,cat,ons ,hrou gh a wireless network where 

ELent 1 ^^ that operates on the mobile device 200. ,n one 

browser. A micro-browser is ! network f browse ? ^n5rT^ n iS?22S n1, T"" br0WSer iS 3 micr °- 
devices. As an example, a micro-browser is nrn rf3 h , !, ™ 6 " ,n,erface such as with hand-held mobile 
Redwood City, CA 94063. Th.^K^^S!ffi^2 5?? * 8 °° Che sapeake Dr.v£ 
apphcation program 202. The memory 204 KdudeT a , persisSnf s tr21%n fi 7 204 St0reS data for use the 
storage 206 is an area of the memory 204 ^^SSSS^f^^ f ° aC , he St0ra£,e 208 The P ersis,ent 
storage 208, on the other hand, is subject to each! ScemeS and r,Z h " l W P' ocessin 3- The cache 

type memory operations. A communicator I l^k 2loE asis normal with cache 

program 202. The memory 204 is also often of a Led size dUtoZ** ^ th ? mem0ry 204 t0 the a PP |ica «on 
particularly hand-held mobile devices t0 lim,ta6ons on size and power for mobile devices 

E^"^ 212 that couples to the 

mobile device 200 to the mail server 110 (o?o1X rer^E fillS 968 synchronous requests for resources by the 
synchronous requests, the synchronous reauest manS ™ a communica «on link 214. In response to the 

other remote servers) via the communteaS S 2U TasvLh re f° UrCeS from the mail serve r 110 (or 
communication link 210. The asynchronous Squel? manaaT 216 ^prl q «f ma " a9er 216 is also C0U P ,ed to 
resources from the mobile device 200 to the mail SrvTr ■ L !Z P <6 f t0 mana9e asvn chronous requests for 
The asynchronous request manager is awJS^J^JZ^,^ SerVer *> via a communication link 218. 
communication link 210. The asynchronous Sstque^ qU6Ue 220 ,hat is also connected to the 

by the asynchronous request manger 216 to the l^J^n T* u ™ ™ * n to * toning 

available to the mobile device 200. Also when "the ne^ork is L ilwi t " T 0 ? SerVerS) when tne network is 
receives incoming resources over a com^n^on fcS Th?S!S ™«! mob J' e device 200. a push manager 222 
bus 210 and is thus able to store the InconiljS^^ 1 ^ 2 m 0 a 4 na9er 222 ' S C ° UP ' ed t0 the c °™-ication 
ISon 2 T 2^s m X.r^ mail ^ application 226. The electronic mai, client 

performed on the mobSe device 200 A? in more detlSt^™ ^ fUnCti ° nS < operati °ns) can be 
is able to operate properly even when the neS app,ication 226 

device (or screen) 228 that is coupled to the communicatbr^ ff n ?%in a 1 Ce 200 also inc,udes a dis P |a V 

?003T St0d S a ^ eleCtrOniCma ^ " 9S ' diSP ' ay d6ViCe 228 

proceLgaoiisp^rLXfSed^^ TT? The el6Ctronic mail cha ™el 

mobile device. As an example. Ihe SanJd ^u^ca^^.K^ T™* reS0UrCes int0 a memor y °f the 
storage 206) of the mobile device 200 "SE« fated in F 2 T^ISStT tl ) e t / T,emo 7 204 ^™«V. the persistent 
needed by the mobile device in interacfing with the elitront S ° f ^ pre - |oadin 9 is that the resources 
avajability because the resources are resident orthemoblfdSce ^ regard,eSS of network 

[0032] The electronic mai, channe. processing 300 in.alry identifies 302 the resources of the electronic mail 
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srarifi b s e srss^rsa , sSsS^arr to mobi,e ^ a «~ * 

pervstent storage 206) of the mobile device loS Here it is assumid S?^*? the memo, V < name V. the 
oaded into the memory of the mobile device The iden'trrcabon Tth 0 !f ate< *?" lc mail channel is to b * P«- 

block J 306 deterS S^\22JSSiS ^SHl? Ch3nne ' * ^ 3 ° 4 ' Then ' a de ™ 
memory 204 (namely, the persstent storage 2$ m5us rated in ?G J tTl^' the memor * P ertains *> »e 
, 0 he selected resource is not stored in the memoW then the rescue 6 . ^o°1 b,0Ck 306 d *e™nes that 

the mail server 110) in an asynchronous manner I =or ^SamL Tth lL?»?^ d I 08 from a remote se ™ (e.g., 
would be forwarded to the asynchronous requ« i!uSVndlln^SS.S.'? a 2> the feSOurce bein 9 
the asynchronous request manager 216 when network availabtlK SlZ o ally ,ransmrtted <° the mail server 1 10 by 
performed in an asynchronous manner there STSt S P?™*- Because the request 308 for the resource is 
arrival of the requested resource. Thus to V^^JZtSZ^!^ ma " Channel Posing 300 to await The 
i asynchronous request queue 220. Th arrrXf ? ^151 SoS^jL^"' f ° f the resource is P |aced he 
for example, via the push manager 222 Previously requested resources are received in the background 

a car^ifsj^ iz:zrj e :r r b,ock 306 ,r n ,he — - * ■» 

loaded. When the decision block 310 deteTmfnes tnat there aTm^,- 68 °' ^ f Ctr0niC mail channel t0 be P«- 
channel processing 300 returns to repeat the block 304 a^uKuMtSSHih* 0 be processe * the ^tronic mail 
resource of the electronic mail channel is VeScte t^^^ ^^^^T 0 ,^^ 3 ^^ 9 ^ 
there are no more resources to be processed tZ SecXr 0 TmT£' n ^ the deciaon block 310 determines that 
[0035J FIG 4 is a flow 6\™Z 75 * V e,ectron,c mai! channel Processing 300 is complete and ends 

invention. ^^ti^p^USnHT!? SSnSST 8 4 °° ^ t0 m embodi ^ * *• 
processing 400 is the basic operation of the ™Ve^J2TS 3 m0b " e device The e,ectronic ma « P"sh 
over a push channel and arriving at to%X^^J& t £X%£ ST" 9 feS ° UrCe ,he ma " 

Lthl an^r^ai,^ ^ ^ * d * n bl0Ck 402 —""n- 

different types of resources over the purtchmnelT^ia^^ S«iT 0 ^ ^ ? an receive a varietv <* 
the mobile device 200 would be received by the push manaae? 222 an ?2 1« r 2 °°' the incomin 9 fesources «° 
decsion block 402 operates to invoke the Sector* mTil Jush SLSJ^E? V** memo,y 204 ln an y event . the 
been received at the mobile device. mJ^SS^tMS^Tf Wh f " a " electronic mail resource has 
rece,ved electronic mail resource is stored 404 in 1 Sn ^V^SS^^ r ^ UrCe has been received ' th * 

K tt0 ^g^^ 

sr wV-* 5 ^^ ,he be9innin9 of the electron,c 

•nventfon. ThTele*^ -cording to an embodiment of the 

zt o, vitt^ the mobile device 200 under 

ausS has is SltRj,*^"? 3 b, ° Ck 502 ^ d — 

bock 502 causes the electronic manist dsptaj "^fi X toWl^n^* mail ,ist - the decisi °" 

^nicmai. list, then the electronic m- « ^SS 8 S5i^^ 0nCe 8 haS requested the 

perslt JSZVS mo^^ *T* ^ ' iSt iS aVai,aWe *™ the 

persistent storage 206 of the memo* 204 VM^'m£S1S * ^ ^ T"* be s,ored in the 
be available from the persistent stoTage due 0 the pre-Sno ?sl F.r VT* the eleCtr ° nic mail ,ist 
electronic mail list may not be available from the Mr£L?ItS2 8 H S^ f )i th J" e are ttme8 in which the 
™J / healectr °nic mail list is not avaSIe from ?,e 2,23" "IT h6 t deC ' Si ° n block 504 de,ermines 

506 to the mail server. Then, a decision block 508 deterS JLl 9 *' 30 e,ectron,c mail list request is sent 
has been received. The response to \ Ee ^e^ks^STS^S?" " ,7^ p0 , nae t0 the e,ectronic mail list r ^"est 
mai, saver. When the daeWon Uoi 50£ \ SSSSL^t hi SSn se W hi d n? U ^ e ' eCtr ° nic mail fet from ^ e 
l.st dsplay processing 500 awaits the recepTon of ^ the ^^in^n^ f ?^' * e 8 ^ rte maB 

request is a synchronous request that causes the mobilP XI T embodiment l the electronic mail list 

before processing continues.' Such > syncS ° f k the "^ted ^source 

manager 212 illustrated in FIG. 2. Once the decision block S'JSL^S ^ . M d ed by the s y nchr °nous request 
received electronic mail list is stored 1 510 ^n^ ^Se52^t^3 ^1 haS been received tne 

decision block 504 determines that the electronic SafS f I!!Lk, ^ m ? 1 b " e dev,ce ' Alter natively. when the 
loading), then blocks 506-510 are bypassed a " aWe fr0m tne Patent storage (due to pre- 

Taxable frtTe ^sfent' storS "» fEJ^V"?- *«*» ^ «- ■« 

Next, the electronic mail list is displiyed *51 f to the use A H the persistent stora 9 e - 
flayed to the user and the system hereafter wafts* ^^^'15 ^ 
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rowT 9 it 5 « 4 ' ,he fl eleC ' r ° niC ma " ' iSt dfeplay pr0cessin 9 500 * c ™P»ete and ends. 

invention. Thf J^T S^^^^ISTX Tf 8 * " emb ° diment ° f 
displayed to the user of the mobile device ^Le FIG sf WhL thTl f f e,ectronic mail «* is presently 

an electronic mail options menu is disollvec I 602^ or T ih^lnh . w Ctr0n ^ ma '' °P eratI0ns Processing 600 begins, 
displayed concurrency or separa tel Sh ^ StecSrS rSS^^T- I" 6 f^ 0 ™ maH ° pti0nS menu can be 
600 effectively waits for a user inZ Sat sEs ? rilL ? e ' eCtr0n ' C ma " °P eration s processing 

performed with respect to the elecEc mail s °f c ^. a Q P ar * c " lar . electromc mail operation (function) to be 
faxing, replying and creating ele«^^ Th6Se e ' eCtr ° niC ma " operations incl "de viewing, deleting. 

Ear eleJtro^VmToSo^to t VTmld tth^cMo"^ T*™ 600 — 

determines whether a view option has been seSd Xn "I! t^ 0 ™ mail list A decision blo <* 604 

been selected, view processing is pfrformed M6 On^eZhJ ^Tl^ ^ determines tna * the view option has 
view option has not been selected a dedsion Sock 608 ^lltH' the d ? CRS,on Wock 604 determines that the 
the decision block 608 determines that the delation tS^J^fiT** ^ h3S bee " Selec,ed When 
the decision block determines that the detete option has not S Vf** pr ° cess,n 9 is Performed 610. When 
(facsimile) option has been selecte When ihe deain b?cS>X25, the " 3 , d h eC ' sion b,ock 612 whe ther a fax 
then fax processing is performed 614 When thTdecisiSn e^Sm-?**^ T™ has been se,ected - 
selected, then a decision block 616 determined ZJS^Z^SJSl determines that the fax option has not been 
determines that a reply option has VS^S^^n J^^ 0 " 3 bee \ selected When the decision block 616 
616 determines that the reply opSnhL no teen seSted^ \ P *%T d 618 " When the decision block 

option has been selected. Whe i a Secfsion 62D^^t2 ^T*" 0011 620 determines a new message 

message processing is performe 6? >Zen ^SSS^SS^ilTO ° Pt, '° n haS been Selected " ne " 
been selected, a decision block 624 ^ determines S ! ! ^ M ,he new messa « e °P 6on h « 
processing 600. When the decision block bTZ^^^^"*' deS,res to exrt the elec »ronic mail operations 
processing 600. then the ^^^r^tS^^^V^ US6r deSireS to exit the electronic mail operation? 
decision Wock 62< ^ determfnt £1^72?^ f"d ends. On the other hand, when thJ 
then the electronic mail operations oroces^no 6flnU!„^ t .1 th ? eectronic mai1 operations processing 600 
that user inputs with respect SSaSSST 0 " b '° Ck 604 a " d SUbse « uent bl ° ?k * - 

UceLng £ ^elZ^J^^^^^ f ~ < of the invention. The view 

, and then to request to ^ I^JSSlSlSr^ ^JSi£TVf, f diSPlayed (See RG 5 > 
message identifier. Next, a decision block 704 ^detlrmines w^Xr ?hT «L1 6 S ^ messa9e is identified b V a 
message is stored in the persistent storLp V fh! ^ the message body associated with the selected 

persistent storage, a ftJiiTKe^SS ^Sl^lotZ^ ^ "VT 396 is not stored in *e 

is thus sent over he wireless data network to thf m ai ftl u the m !!' server This re « uest for th e message body 
device, the request ca^nofbe «J<S2fl5f £2mSS TnTL^' Whe " th t network is mailable to the' mobile 
706 determines whether re P ?y to the ^SS^S^S^^^^ F °"°T, a b,0Ck 706 ' 3 decision «*** 
decision block 708 determines tha the re^iZ iTf^ has been received from the ma '' server. When the 
view processing 70 ^ aS tn7 arrfvaT of toe S ^ S I^ n0t yet r6Ceived from the mail ^ 
(including the message booV) has Sen ?ecehid K J ?> "^J? bl °^ ks 708 deterr " i "es that the reply 
device, .n one emboLent^hes^nS^^ storage of the mobile" 

receives the reply from the mail server manager <nz illustrated in FIG. 2 transmits the request and 

Sn 1^!™*^ 7 °0. a - able to be bypassed when the 

Thus, when the persistent storage h» S ^nS ftej£?2 ^ ^ '?K the PerS,St6nt St0rage of the mobile device 
electronic mail channel) thatl dS ed Mh^'^S^^o^ message body (i.e.. a resource of the 
and thus without network delays Processing 700 can operate without regard to network availability. 

She S slSge 1 thrrsage S TS^JT" ** ^ ^ mSSSage b ° dy iS f0U " d 
storage. The retrieved message bodl ?i ^ then Sllved 7if fh "J.^sage ,s retrieved 712 from the persistent 
block 714, the view processing^ 714 ° n the d,spla y dev,ce of the mobile device. Following 

ofJfJlio^^ t0 J hC *» processi " 9 TOO according to an 

between the block 712 and 714 5th?SS ^Si^ < L^SK re*S Them^ 9 / 50 tha J- ^ be Perf ° rmed 
allows the mobile device to asynchronously (i e backaround ^22^1 taJi * message marking processing 750 
have been read. The message tmSS^Mm^^^Z^ ,nform j he ma " server of th °se messages that 
message has already been Lc nt Te f^^^^^^XTTn deC ' S, ° n b '° Ck 752 whether the selected 
having been read because the ^messace fta *3iS^?7i?f ^ been then the messa9e is marked as 
message (i.e., the local cop?) asTefn? ^T£s^^ ^l^ 6 message - After markin 9 »e 

queue. The message read request wffl I se^to Wtol^^i ^ «. ♦ ptaced 756 ,he as yr>chronous message 
thus allow the mai. server to J^of^n^^^T^ 3 PM < meSS39e has ^ -ad. an'd 
[0049] FIG. 8 is a flow diagram of the delete processing 800 according to an embodiment of the invention. The 
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?n e ncn, Pr0CeSSm9 800 is ' for exam P |e . Performed by block 610 illustrated in FIG 6 

[UU5UJ Thfl <4~\~i~ ; _ 



has acted J'selecltne^of T ISSJS ISJ^SSJ^ V*?"? * be Typica "* the 

selected message is deleted I ^S^l^ * t G de,e,l0n ° f «*cted message, then the 

persistent storage. The electronic ma I lisffe elle^ 808 lom * ma ' S the " retneved 808 from the 
electronic mail list is provided The retrieved eleSc mi, £T Persistent storage so that an updated 
example, with respect to the mobHe dev£e So tSSS Tf£ 2 thp 6 !^' 3 ^ ?!° to the user As an 
the display device 228. Additionally, a deteSm^e^eJis S e L?i5K ren, ° ^ tet Ca " be diSplayed 0n 
example with resc-eet to Fir; o th* h!7^L 1 9 request is placed 812 in an asynchronous request queue For 

226 and TolS by ^i££^SS! , SSTt^ * th6 e ' eCtr ° niC ^il client VpBcaS, 

^tihtonousfequeAlBMgSt^nu^t^^S asynchronous request queue 220. Thereafter, the 

electronic mail chent application TX^tS^A applicatior^ ' SSS! ST^T * T™™ * the 
queue 220. Thereafter, the asynchronous request manBa^R r^nr,^ , the ^V™*™™" request 

1104 a recident IS 3!?^ PTCeS ? n - 9 disp,ays 1102 a messa 9e recipient screen. A user then enters 

displayed 1116. Additionally, a new mesttj^qSTSSd H8?n a ™ k neW mSSSage Was sent is 

with retnori tn t=ir o IC " M,C5,!>£1 9 e request is placed 1118 in an asynchronous request queue For exam Die 

Fo S ng W oc k 1118,^ *™ -two* lability permfe, 

2 h™,?? aSy "« h r ° n0US transmissions from ^e mobOe device to Ihe remote server (e g mail server) enable the 
mob, le dev,ce to continue processing while these asynchronous transmissions occur in tL^ZTJSK 
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wmmsm 

misp 

^her JZSZ T2j^j%S3T** ? ™« *>c k ,302 amines 

. — _ — ___ 
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resource in the push aueue is a EP 0 994 608 A2 

the size of *;alcJoiS, 0a, "™ , ' can """a* <° «">« »<* 2»w2 iSLl*" J"** *"*• F °' 

co e m m m0bi,e t - «^"S» , ^ m ? a Fr ,e 2 d re e 1 m 4 o° b 0 , aCC H Ordin9 ,0 an ° thef emb0 ^-t of the invention LiKe 
luwuj Tne mob|(e dev includes an fl „ni,w « '**Poraaic or high-latency conditions are Dresenr 

tm^mmm 

lUUMj Tne pusn manag uu ^ nilcKa H 

n rhe user interfaces operate to display the 
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various lists on a display 1499 c h ■• EP 0 994 608 A * 
Claims 

a memorv sto-age device that Mores electronic men resource* 

- «~ » - — * « 

a; ,:r **• - - - *~ rr:,?r— - srsr i-r-s 

a^av^ce,,,^,,,,,^^,,^^^^^^^^^ 
2 ' «~^%^^^^ M reso 0 rces ,„ sa,< memo „ 

PMMr, electronic ma, message ^ i nl0 . ^ ae „ e „ ^ ^ 
receiving a retjuest to view an electronic mall trst 

determining whether «. , ^ ((om „ e ^ ^ rfffie ^ ^ 

K^nt^^^ tne .conic mail 

displaying the received electronic mail list. 

icSfl? ~" " — 5 —* - — * * ft. — ■ d „. ne^,,, ,„ , Be moMe aeto |s 
-an^CrSte^ _ ma „ 
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displaying an electronic mail list on * nie^ 

-^««».-„ i r^ i P a»^' : «^. « e c,o* ma , „ 

computer program code configured to disp.ay the received eiectronic mai. list. 
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